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THE MC68230 PARALLEL 
INTERFACE/TIMER 
PROVIDES AN EFFECTIVE 
PRINTER INTERFACE 


INTRODUCTION 

The MC68230 Parallel Interface/Timer (PI/T) provides 
versatile parallel interface ports and an operating system- 
oriented timer to MC68000 microprocessor systems. This ap¬ 
plication note describes a PI/T interfaced with a Printronix 
Model 300 printer using the industry-standard Centronics in¬ 
terface. 

THE PRINTRONIX INTERFACE 

The standard Centronics printer interface allows transfer 
of byte-wide, parallel dat a transfer under co ntrol o f two real- 
time handshake lines, DATA STROBE, and ACKNLG 
(acknowledge). Short data setup (50 ns) and hold t imes, with 
respect to the active edge of the DATA STROBE input, are 
required. 

Three additional printer status signals, BUSY, PE (printer 
error), and SECT (select) are provided to maintain printer 
status. A timing diagram for the Centronics interface im¬ 
plemented in the Printronix 300 is shown in Figure 1. When 
PE is high, the printer is in check (disabled due to an internal 
condition such as out of paper or mtilfunction). When SECT 
is high, the printer is on line and not in check. 

When the printer is initially ready to receive data, its PE 
(printer error) output furnishes a logic low (inverted and ap¬ 
plied to PCO of the PI/T) and its SECT (select) line furnishes 
a logic high (inverted and applied to PCI of the PI/T). The 
PI/T then outputs data (on the PA0-PA6 lines) plus a logic 
low data strobe pulse (on the H2 pin). Once the printer ac¬ 
cepts the data character, it returns a low ACKNLG pulse (in¬ 
verted at PI/T HI). This indicates that the printer is ready 
for the next character. If the printer is currently unavailable, 
due to a form-feed or printing operation, it outputs a high 
BUSY signal (which is inverted before application to the 


PI/T on t he PA7 lin e); however, in this case it does not out¬ 
put the ACKNLG pulse until it (the printer) is again 
available. 

USING THE PI/T 

The PI/T requires only buffer and inverter devices to con¬ 
nect directly to the printer as shown in the schematic diagram 
of Figure 2. This implementation does not use the optional 
Printronix expanded character set; thus, only seven data bits 
need be connected. Seven data bits are sufficient for ASCII 
characters and for use in the plot mode. The PI/T is pro¬ 
grammed for the unidirectional 8-bit mode, with double- 
buffered output transfers chosen for Port A. (Port B, H3, 
and H4 are not used and are totally independent of the 
printer interface; therefore, a second printer could be 
attached.) Port A bits 0 through 6 are double-buffered by the 
PI/T and are applied to the printer by a 74LS244 driver. Port 
A bit 7 is not required as a data output in this application and 
is used as the BUSY input from the printer. (When double- 
buffered output transfers are chosen, input pins such as PA7 
are unbuffered and the instantaneous level of the pin may be 
read by the microprocessor.) Depending upon operating 
system requirements, BUSY, PE, and SECT may or may not 
be useful and are not rigorously supported in the driver soft¬ 
ware provided in Figure 3. 

The H2 pin is configured, for use with the PI/T, in the 
pulsed output handshake protocol. This pin produces a 
4-clock cycle pulse (5(X) nanoseconds @ 8 MHz) whenever 
new data is available at the P ort A output pins. This pulse is 
received by the printer as its DATA STROBE input and is 
used to lat ch the newly available character. The low active 
ACKNLG output from the printer is then received by a 
74LS14 and applied as an inverted input to the edge-sensitive 


I 


©MOTOROLA INC., 1982 





FIGURE 1 — Centronics Interface, Timing Requirements 


HI handshake pin of the PI/T. An active-going edge (in this 
case the trailing edge, as shown in Figure 2) on HI indicates 
that the printer is ready to accept the new data. Each of the 
PI/T handshake pins (H1-H4) may be programmed in¬ 
dependently as either active high or active low inputs. In this 
application, to satisfy printer timing requirements, HI was 
chosen (by the Port General Control Register con figuration) 
to recognize the trailing edge of the 4-microsecond ACKNLG 
pulse. Refer to the timing diagram of Figure 1. 

DOUBLE-BUFFERING 

The PI/T provides the full double-buffered data path sup¬ 
port required in this application. The best throughput to the 
printer is obtained if the data transferring device (the PI/T) 
is always rea dy to pas s the next character to the printer 
whenever the ACKNLG pulse is received. The Pl/T contains 
two fully-static 8-bit latches in the output d ata path of each 
port. Thus, assuming both are full, when the ACKNLG pulse 
is recognized by the active-going edge on HI, the next 
character is immediately moved to the pins without waiting 
for interrupt or direct memory access latency. At that time, 
an interrupt or direct memory access request (as pro¬ 
grammed) is made to fill the remaining buffer(s). To take 
best advantage of multiple buffering levels, I/O driver soft¬ 
ware should check the HIS status (bit 0 in the Port Status 
Register) after each character is stored to verify that room is 
not available for an additional character. The driver should 
return only when the data path is full. Somewhat primitive 
but functional driver software is shown in Figure 3. 

PI/T — PRINTRONIX DRIVER SOFTWARE 

This group of routines constitutes the device driver portion 
of a line printer controller. Some routines are not shown 
(such as LPCLOSE), but the actual device interface code is 


illustrated. The basic sequence of operations is as follows: 

1) When the system is booted, LPOPEN is called by a 
server process. This routine is called only once. 

2) When the server process has output to print, it makes 
successive calls to LPWRITE, passing the buffer ad¬ 
dress and character count. LP WRITE returns status in 
DO. 

3) LPWRITE enables interrupts after checking the 
printer status. The PI/T generates an interrupt as soon 
as interrupts are enabled. 

4) The LPINTR interrupt routine then initiates the out¬ 
put of characters to the printe r. After ea ch character is 
received by the printer, an ACKNLG signal is sent 
back to the PI/T. This initiates moving another 
character to the output lines and also initiates move¬ 
ment of a new character to the double-buffered input. 
Thus, the double-buffering scheme of the PI/T will 
avoid many unneeded interrupts. In fact, tests have 
shown that the PI/T and printer can usually keep up 
with the processor and need only interrupt after a line 
feed is output. 

This simple routine requires modification in order to be in¬ 
tegrated into a real operating system. After the line labeled 
Ipwgo is executed, the program loops while waiting for the 
finished flag (finflag) to be set. At this point, a semaphore 
call may be made to suspend the LPWRITE process. When 
all characters are printed, LPINTR will wake-up LPWRITE, 
which will return. In addition, more complicated buffering is 
generally used. 

The MC68230 is as easy to program as most line printer 
controllers and is much cheaper. The program of Figure 3 
demonstrates that the MC68230 is easy to use in this common 
application. 






MC68000 

Osc. 


May Be Independent 



FIGURE 2 - MCeaOOO-PI/T-l 


MC68230 

Osc. 



To 

Printronix 
Model 300 
(Centronics 
Interface) 


Interface Schematic Diagram 













MGTGRGLA Semiconductor Products Inc. 

Colvilles Road, Kelvin Estate - East Kilbride/Glasgow - SCOTLAND Printed in Switzerland 





TT 

* 

MC68000 

- MC68230 PI/T LINE PRINTER DRIVER 


* 

MICROPROCESSOR 

DIVISION, MOTOROLA INC. 


« 

VICTOR 

SCHERER 

AND WILLIAM G. PETERSON 


* 

AUGUST 

13, 1981 




« 

PRINTRONIX PRINTER, CENTRONICS INTERFACE 


PIT 


EQU 


♦COOO ' 

BASE ADDRESS FOR PI/T 

PCCR 


EGU 


PIT+1 

PORT GENERAL CONTROL REGISTER 

PSRR 


EQU 


PIT+3 

PORT SERVICE REQUEST REGISTER 

PADDR 


EQU 


PIT+5 

PORT A DATA DIRECTION REGISTER 

PIVR 


EQU 


PIT-t-*B 

PORT INTERRUPT VECTOR REGISTER 

PACR 


EQU 


PIT+*D 

PORT A CONTROL REGISTER 

PADR 


EQU 


PIT+*11 

PORT A DATA REGISTER 

PC DR 


EQU 


PIT-t-*19 

PORT C DATA REGISTER 

PSR 


EQU 


PIT+*1B 

PORT STATUS REGISTER 



ORG 


*800 


* 

« 

LPOPEN 

— CALLED ONCE 

BY A PRINTER SERVER ROUTINE 

* 


SETS 

UP PI/T 

FOR UNIDIRECTIONAL 8-BIT 

MODE, PORT A OUTPUT, 

* 


H2 PULSED OUTPUT HANDSHAKE PROTOCOL 


LPOPEN: 


ST 


FINFLAG 

*FF = FINISHED, IDLE 



MOVE. B 


#*7F, PADDR 

7 BITS OUT, HIGH BIT IN 



MOVE. B 


#*78, PACR 

PORT A SUBMODE 01, PULSED 



MOVE. B 


#*10,PGCR 

ENABLE PORT A, MODE 0 



MOVE. B 


#*40,PIVR 

INTERRUPT VECTOR 



MOVE. B 


#*18,PSRR 

ENABLE INTRPINS 



RTS 




« 






« 

LPWRITE 

— USER 

EXECUTES TRAP INSTRUCTION, TRAP 

HANDLER SETS UP 

« 


PARAMETERS 

: DO = BYTECOUNT, AO = BUFFER ADDRESS 

* 


IF PRINTER 

IS ONLINE, ROUTINE JUST ENABLES INTERRUPTS 

* 


DO - 

RETURN 

STATUS 


LPWRITE 


CLR. B 


FINFLAG 

JUST STARTING 



MOVE. L 


DO, BYTECNT 

SAVE USER PARAMS 



MOVE. L 


AO, BUFFADDR 




BTST 


#0, PCDR 

IN CHECK? 



BEQ. S 


NOGO 




BTST 


#1, PCDR 

ON LINE? 



BEQ. S 


LPWGO 


NOGO: 


ST 


DO 

SET TO ALL 1'S 



RTS 




LPWGO, 


BSET 


#1,PACR 

ENABLE HIS INTERRUPT 

LPWl; 


TST. B 


FINFLAG 

WAIT FOR FINFLAG EQU *FF 



BEQ. 5 


LPWl 

OS BUFFERING HERE 



CLR. B 


DO 

NORMAL STATUS 



RTS 



RETURN 



FIGURE 3 — Printronix Driver Software 
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* LPINTR 

-- INTERRUPT 

SERVICE ROUTINE. (JETS 

CHARS FROM BUFFER AND 


SENDS 

TO PI/T TO PRINT. 



WHFN 

DONE, 

DISABLES INTERRUPTS. 


LPINTR: 

MOVE.L 


AO,-(SP) 

SAVE AO 


MOVE.L 


BUFFADDR, AO 

GET BUFFER ADDRESS 


TST. L 


BYTECNT 

IS THERE ANYTHING TO PRINT? 


BEQ. S 


EMPTY 

IF NOT, FINISHED 

PRINTSOME: 

MOVE.B 


(AO) + , PADR 

MOVE TO PI/T 


SUBQ. L 


#1,BYTECNT 

DEC CHAR COUNTER 


BEQ. S 


EMPTY 

STOP IF OUT OF CHARS 


BTST 


#0,PSR 

SEE IF ROOM FOR ANOTHER CHARACTER 


BNE. S 


PRINTSOME 

IF SO, DO IT AGAIN 


BRA S 


NOTREADY 

NOT RDY 

EMPTY: 

BCLR 


#1,PACR 

DISABLE HIS INTERRUPTS 


ST 


FINFLAG 

SET FINISHED STATUS 

NOTREADY: 

MOVE.L 


AO, BUFFADDR 

SAVE BUFFER ADDRESS 


MOVE.L 
RTE 


(SP)+,AO 

RESTORE AO 

BUFFADDR 

DC. L 

0 



BYTECf4T 

DC. L 

0 



FINFlAG 

DC. B 

0 




END 





FIGURE 3 — Printronix Driver Software 
(Concluded) 
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